<html><head><meta charset="utf-8"/><title>基本语法</title></head><body><h1>基本语法</h1><div class="x-wiki-content x-main-content">
 <h3>
  语法
 </h3>
 <p>
  JavaScript的语法和Java语言类似，每个语句以
  <code>
   ;
  </code>
  结束，语句块用
  <code>
   {...}
  </code>
  。但是，JavaScript并不强制要求在每个语句的结尾加
  <code>
   ;
  </code>
  ，浏览器中负责执行JavaScript代码的引擎会自动在每个语句的结尾补上
  <code>
   ;
  </code>
  。
 </p>
 <pre><code class="language-!">让JavaScript引擎自动加分号在某些情况下会改变程序的语义，导致运行结果与期望不一致。在本教程中，我们不会省略;，所有语句都会添加;。
</code></pre>
 <p>
  例如，下面的一行代码就是一个完整的赋值语句：
 </p>
 <pre><code>var x = 1;
</code></pre>
 <p>
  下面的一行代码是一个字符串，但仍然可以视为一个完整的语句：
 </p>
 <pre><code>'Hello, world';
</code></pre>
 <p>
  下面的一行代码包含两个语句，每个语句用
  <code>
   ;
  </code>
  表示语句结束：
 </p>
 <pre><code>var x = 1; var y = 2; // 不建议一行写多个语句!
</code></pre>
 <p>
  语句块是一组语句的集合，例如，下面的代码先做了一个判断，如果判断成立，将执行
  <code>
   {...}
  </code>
  中的所有语句：
 </p>
 <pre><code>if (2 &gt; 1) {
    x = 1;
    y = 2;
    z = 3;
}
</code></pre>
 <p>
  注意花括号
  <code>
   {...}
  </code>
  内的语句具有缩进，通常是4个空格。缩进不是JavaScript语法要求必须的，但缩进有助于我们理解代码的层次，所以编写代码时要遵守缩进规则。很多文本编辑器具有“自动缩进”的功能，可以帮助整理代码。
 </p>
 <p>
  <code>
   {...}
  </code>
  还可以嵌套，形成层级结构：
 </p>
 <pre><code>if (2 &gt; 1) {
    x = 1;
    y = 2;
    z = 3;
    if (x &lt; y) {
        z = 4;
    }
    if (x &gt; y) {
        z = 5;
    }
}
</code></pre>
 <p>
  JavaScript本身对嵌套的层级没有限制，但是过多的嵌套无疑会大大增加看懂代码的难度。遇到这种情况，需要把部分代码抽出来，作为函数来调用，这样可以减少代码的复杂度。
 </p>
 <h3>
  注释
 </h3>
 <p>
  以
  <code>
   //
  </code>
  开头直到行末的字符被视为行注释，注释是给开发人员看到，JavaScript引擎会自动忽略：
 </p>
 <pre><code>// 这是一行注释
alert('hello'); // 这也是注释
</code></pre>
 <p>
  另一种块注释是用
  <code>
   /*...*/
  </code>
  把多行字符包裹起来，把一大“块”视为一个注释：
 </p>
 <pre><code>/* 从这里开始是块注释
仍然是注释
仍然是注释
注释结束 */
</code></pre>
 <p>
  练习：
 </p>
 <p>
  分别利用行注释和块注释把下面的语句注释掉，使它不再执行：
 </p>
 <pre><code class="language-x-javascript">// 请注释掉下面的语句:
----
alert('我不想执行');
alert('我也不想执行');
</code></pre>
 <h3>
  大小写
 </h3>
 <p>
  请注意，JavaScript严格区分大小写，如果弄错了大小写，程序将报错或者运行不正常。
 </p>
</div>
</body></html>